home *** CD-ROM | disk | FTP | other *** search
/ Visual Cafe 3 / Visual Cafe 3.ISO / Vcafe / JFC.bin / AbstractBorder.java < prev    next >
Text File  |  1998-06-30  |  3KB  |  80 lines

  1. /*
  2.  * @(#)AbstractBorder.java    1.17 98/02/02
  3.  *
  4.  * Copyright (c) 1997 Sun Microsystems, Inc. All Rights Reserved.
  5.  *
  6.  * This software is the confidential and proprietary information of Sun
  7.  * Microsystems, Inc. ("Confidential Information").  You shall not
  8.  * disclose such Confidential Information and shall use it only in
  9.  * accordance with the terms of the license agreement you entered into
  10.  * with Sun.
  11.  *
  12.  * SUN MAKES NO REPRESENTATIONS OR WARRANTIES ABOUT THE SUITABILITY OF THE
  13.  * SOFTWARE, EITHER EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE
  14.  * IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR
  15.  * PURPOSE, OR NON-INFRINGEMENT. SUN SHALL NOT BE LIABLE FOR ANY DAMAGES
  16.  * SUFFERED BY LICENSEE AS A RESULT OF USING, MODIFYING OR DISTRIBUTING
  17.  * THIS SOFTWARE OR ITS DERIVATIVES.
  18.  *
  19.  */
  20. package com.sun.java.swing.border;
  21.  
  22. import java.awt.Graphics;
  23. import java.awt.Insets;
  24. import java.awt.Rectangle;
  25. import java.awt.Component;
  26. import java.io.Serializable;
  27.  
  28. /**
  29.  * A class which implements an empty border with no size.  
  30.  * This provides a convenient base class from which other border 
  31.  * classes can be easily derived.
  32.  * <p>
  33.  * Warning: serialized objects of this class will not be compatible with
  34.  * future swing releases.  The current serialization support is appropriate 
  35.  * for short term storage or RMI between Swing1.0 applications.  It will
  36.  * not be possible to load serialized Swing1.0 objects with future releases
  37.  * of Swing.  The JDK1.2 release of Swing will be the compatibility
  38.  * baseline for the serialized form of Swing objects.
  39.  *
  40.  * @version 1.17 02/02/98
  41.  * @author David Kloba
  42.  */
  43. public abstract class AbstractBorder implements Border, Serializable
  44. {
  45.  
  46.     /** This default implementation does no painting. */
  47.     public void paintBorder(Component c, Graphics g, int x, int y, int width, int height) {
  48.     }
  49.  
  50.     /** This default implementation returns the value of getBorderMargins. */
  51.     public Insets getBorderInsets(Component c)       { 
  52.         return new Insets(0, 0, 0, 0);
  53.     }
  54.     
  55.     /** This default implementation returns false. */
  56.     public boolean isBorderOpaque() { return false; }
  57.  
  58.     /** This is a convience method that calls the static method. */
  59.     public Rectangle getInteriorRectangle(Component c, int x, int y, int width, int height) {
  60.     return getInteriorRectangle(c, this, x, y, width, height);
  61.     } 
  62.  
  63.     /** This method returns a rectangle using the arguements minus the
  64.       * insets of the border. This is useful for determining the area
  65.       * that components should draw in that will not intersect the border.
  66.       */
  67.     public static Rectangle getInteriorRectangle(Component c, Border b, int x, int y, int width, int height) {
  68.         Insets insets;
  69.     if(b != null)
  70.         insets = b.getBorderInsets(c);
  71.     else
  72.         insets = new Insets(0, 0, 0, 0);
  73.         return new Rectangle(x + insets.left,
  74.                                 y + insets.top,
  75.                                 width - insets.right - insets.left,
  76.                                 height - insets.top - insets.bottom);
  77.     }
  78.  
  79. }
  80.